package com.taobao.system.service.impl;

import com.taobao.basic.service.impl.BaseServiceImpl;
import com.taobao.system.domain.Menu;
import com.taobao.system.mapper.MenuMapper;
import com.taobao.system.service.IMenuService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

@Service
public class MenuServiceImpl extends BaseServiceImpl<Menu> implements IMenuService {

    @Autowired
    private MenuMapper menuMapper;
    @Override
    public List<Menu> menuTree() {
        // 1.查询所有
        List<Menu> all = menuMapper.loadAll();

        // 2.准备一个map
        HashMap<Long, Menu> map = new HashMap<>();

        // 3.把所有数据放入map中
        for (Menu menu : all){
            map.put(menu.getId(),menu);
        }
        // 4.准备一个list,保存处理之后的数据
        ArrayList<Menu> menuTree = new ArrayList<>();
        for (Menu menu : all){
            // 顶级部门
            if (menu.getParent_id()==null){
                menuTree.add(menu);
            }else {
                // 获取parent_id
                Long parent_id = menu.getParent_id();
                // 获取上级部门对象
                Menu partDept = map.get(parent_id);
                // 把自己放入上级部门的children中
                partDept.getChildren().add(menu);
            }
        }
        // 返回部门树
        return menuTree;
    }

}
